草庐IT

MySQL - 多个表上的大删除

全部标签

ruby-on-rails - Rails - 如何在不重复的情况下为多个角色声明 attr_accessible

有没有一种方法可以为多个角色声明attr_accessible而无需大量重复?如果我有多个用户角色,并且允许每个角色编辑不同的属性子集,那么我的attr_accessible声明如下所示:attr_accessible:first_name,:last_name,:active,:as=>:adminattr_accessible:first_name,:last_name,:as=>:managerattr_accessible:first_name,:last_name,:as=>:guest我也愿意A)定义一组可以共享的可访问属性不同的角色或B)定义一组可以访问相同角色的角色属性

ruby - Ruby 中从 URL 中删除参数的最优雅的方法是什么?

我想通过名称从URL中取出一个参数,但不知道它是哪个参数,然后重新组合URL。我想我自己使用CGI或URI编写一些东西并不难,但我想这样的功能已经存在了。有什么建议吗?在:http://example.com/path?param1=one¶m2=2¶m3=something3输出:http://example.com/path?param2=2¶m3=something3 最佳答案 我更喜欢使用:require'addressable/uri'uri=Addressable::URI.parse('http

ruby-on-rails - 将路由文件拆分为多个文件

我正在使用Rails3应用程序工作,我想根据子域将路由拆分为单独的文件。现在我的routes.rb文件中有这个:Skateparks::Application.routes.drawdoconstraints(:subdomain=>'api')doload'routes/api.rb'endend在我的routes/api.rb文件中我有:resources:skateparks这似乎不起作用,因为如果我运行rakeroutes我明白了undefinedmethod`resources'formain:Object此外,如果我尝试导航到http://0.0.0.0:3000/我得到:

ruby-on-rails - 压缩存储在 S3 上的所有回形针附件

Paperclip是一个很棒的Rails上传插件。在本地文件系统或AmazonS3上存储上传似乎效果很好。我假设将文件存储在本地主机上,但此应用需要使用S3,因为它将托管在Heroku上。我如何在一次压缩下载中从S3获取所有上传/附件?从本地文件系统中获取文件的zip似乎很简单。它从S3获取文件让我感到困惑。我认为这可能与ruby​​zip处理URL引用的文件的方式有关。我尝试了各种方法,但似乎无法避免错误。format.zip{registrations_with_attachments=Registration.find_by_sql('SELECT*FROMregistratio

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby - 从 map 返回多个值

有什么办法可以做到:a=b.map{|e|#returnmultipleelementstobeaddedtoa}不是为要添加到a的每个迭代返回单个对象,而是可以返回多个对象。我目前正在通过以下方式实现这一目标:a=[]b.map{|e|a.concat([x,y,z])}有没有办法在一行中完成此操作而无需预先声明a=[]? 最佳答案 使用Enumerable#flat_mapb=[0,3,6]a=b.flat_map{|x|[x,x+1,x+2]}a#=>[0,1,2,3,4,5,6,7,8]

ruby-on-rails - Heroku 上的数据库连接

哇,我已经被困在这个问题上好几天了。我无法连接到Heroku上的database.yml。我在使用Cedar和ruby​​1.9.2。我的开发和测试数据库是sqlite3,生产数据库是postgreSQL以应对Cedar规则。这是我的ruby​​脚本中的代码:Rails.env.production??(env="production"):(env="development")dbconfig=YAML::load(File.open('config/database.yml'))[env]ActiveRecord::Base.establish_connection(dbconfig

ruby - 从字符串中删除双引号

我正在尝试从MySQL数据库中获取数据并使用Ruby将其重新格式化为纯文本文件。我的一些MySQL数据包含双引号,如下所示:Matthew"Matt"Perry我需要删除这些引号并将它们替换为其他内容,|例如。我在stackoverflow上发现了另一篇关于删除引号的帖子,建议如下:s.scan(/'(.+?)'|"(.+?)"|([^]+)/).flatten.compact但这会返回完整的字符串(带双引号)。我怎样才能得到Matthew|Matt|Perry代替? 最佳答案 如果您不想修改,可以这样做:new_s=s.gsub/

ruby-on-rails - gem install mysql2 v '0.3.11' 无法在 Yosemite 上运行

在ruby​​版本1.9.3(rvm)上执行mysql2版本0.3.11的捆绑安装或直接gem安装时,我收到以下错误。但是当我安装最新版本0.3.16时它可以工作。我还包含了我的gcc版本以供引用。Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./Users/ginocarlocortez/.rvm/rubies/ruby-1.9.3-p547/bin/rubyextconf.rbcheckingforrb_thread_blocking_region()...yescheckingforrb_wait_for_si

ruby 为给定值获取多个哈希键的有效方法

从给定值中获取所有哈希键的最有效方法是什么。my_hash={"a"=>"aa","b"=>"bb","c"=>"bb"}我想将散列“bb”作为输入值并将它们的所有键(b,c)作为数组返回只返回一个键:my_hash.index("bb")#returnsonlyb这有效但似乎效率低下:my_hash.select{|k,v|v=='bb'}.map{|i|i[0]}#returnsbandc我已经阅读了所有文档。我觉得我缺少了一些明显的东西。谢谢!更新:我最终切换了哈希创建的键和值,并使用数组作为值。这是一个更有效的解决方案。如果需要,请参阅下文了解进行值(value)查找的最佳方法